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1, INTRODUCTION 

A UAV or robot without path planning does not have the abilities to complete the surveillance and 
rescue tasks [1] like 2001 World Trade Centre collapse [2], Hurricane Katrina in 2005 [3], and the 2011 
Tohoku tsunami and earthquake [4]. Therefore, path planning is necessary for it to aid human operators in 
dangerous circumstances, such as natural disasters and hazardous areas [5]. There are mainly three kinds of 
path planning techniques namely combinatorial, sample based and biologically inspired and they are 
illustrated in Figurel. 

In sampling based method, rapidly-exploring random tree (RRT) does not always provide the 
optimal result and probabilistic roadmap (PRM) is expensive without any guarantee to find the path. Genetic 
Algorithm (GA) is considered as a biologically inspired method and it is currently utilized in energy efficient 
path planning. But it also cannot guarantee the achievement of the optimal path because local minima may 
occur in narrow environments. 

Moreover, GA is computationally expensive and practically not complete. Moreover, when the 
fitness functions are not well-defined, it usually tries to converge along local optima of the problem avoiding 
its global optimum. A self-adaptive differential evolution (SDE) algorithm can eliminate the required manual 
tuning of control features [6]. Particle Swarm Optimization (PSO) has real time effect but it can easily fall 
into local optima in many optimization problems. Furthermore, there is no general convergence theory 
applicable to PSO in practice and its convergence time is also uncertain for multidimensional problems [34]. 
Ant Colony Optimization (ACO) does a blind search and thus, it is not suitable for energy saving path 
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planning due to the lack of optimal result. Apart from very slow and very high cost functions, 
Simulated Annealing (SA) is also not capable of finding the optimal path. 
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Figure 1. Classification of path planning approaches 


Under the combinatorial method, potential field (PF) sometimes does not find the goal because of 
local minima issue. The necessary adjustments are required for cell decomposition (CD) as per the situation; 
e.g., in exact CD, the cells are not predefined, but they are selected based on the location and shape of the 
obstacles within the configuration space (C-space) [7]. Visibility graph (VG) is more energy efficient than 
voronoi diagram (VD) in combinatorial method under roadmap technique because the latter fails to create the 
shortest path [8,33] for which there is a high plausibility of wastage in energy consumption and cost. 

UAV has limited energy or power or fuel and this restrains it from a longer time flight. Therefore, 
it 1s important for a UAV to adopt a path planning algorithm ensuring that the traversed path must be 
collision-free and optimal in terms of path length and energy efficiency. The most common problem in path 
planning that a UAV has to come across is a set of obstacles through which it needs to fly in between the 
given starting and target points [8] within the specified area. These obstacles may not be fixed at one location 
and can pop up during the fly. Configuration space (C-space) 1s a most commonly used technique for path 
planning to denote the position of obstacles and the information of free space in a given area. It provides 
detailed position information of all points in the system and is the space for all configurations. It assumes the 
UAV as a point and adds the area of the obstacles so that the path planning can be done more efficiently. 
C-space is obtained by adding the UAV radius while gliding along the edge of the obstacles and the border of 
the search space. An illustration of a C-space for a circular UAV is shown in Figure 2. 
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(a) 
Figure 2. Configuration space for a UAV 
2. GRAPH SEARCH ALGORITHM 
Graph search algorithms have been used extensively in past studies for energy efficient path 


planning. It generally determines a path from starting to target points by checking some nodes/states. 
Without any existing path, it will report failure. Several graph search methods are discussed below. 
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2.1. Depth-First Search (DFS) 

DFS moves towards the goal as quickly as possible and searches a path till getting the dead end. 
DFS may miss large portions of the workspace [7, 9] since it tries to search several paths at a time before 
completing one path. It can be applied to find a path among many possible paths. However, DFS is an 
uninformed search since the cost function is not used in deciding the suitable direction and in estimating that 
how far is the target point from the current node.DFS may be slightly faster in case it picks the leaf node path 
that contains the required node, but it is not complete. When numerous solutions are in the tree where 
everyone is at a comparable ‘depth’, then there is a chance to miss a larger part of the tree from exploring. 
Conversely, there is a chance for it to stuck in the lengthy blind alleys, whereas fewer steps solution path 
exists and hence, it is not the best solution. When the depth values in the search are fixed, it prevents the 
above issue. But this method is not much effective. DFS is good in selecting one solution among many 
possibilities without any prior knowledge and not suitable when only one or the shortest solution exits. 
In DFS, the required memory is linear against the search graph making it advantageous. It keeps the record of 
the nodes in the ‘current’ path leading to less memory requirement for tree search. It 1s an exhaustive and 
systematic search method that utilizes every node in the finite search-space. 

DFS incorporated Genetic algorithm to discover the optimal processing sequence of features of a 
part (PSFP) that reduces the feature transitions’ energy consumption by 28.60 % [11]. A smaller search space 
was explored faster with reduced cost by another extended depth-first search (EDFS) algorithm [32]. 


2.2. Breadth-First Search 

Moore introduced the Breadth-first Search algorithm in 1957 [12]. It 1s a systematic search 
algorithm because it first expanded the shallow nodes by searching all the next level nodes of the path and 
then it takes the next step. However, like DFS, Breadth-first Search is an uninformed search to find the 
shortest path in first attempt. It 1s applicable in limited solutions that use comparatively minimum steps [13]. 

Breadth-first Search algorithm uses more memory and traverses all nodes. It always provides first 
solution in finding shortest path or determines a path with minimum steps without getting stuck in any blind 
alleys. The main feature of Breadth-first Search 1s that when all the graph’s edges have no weight or same 
weight, the shortest path lies within the first visited node and the source node. This algorithm is complete if 
one exists. It is also a systematic and exhaustive search technique that eventually tries all the nodes in the 
search space (if it is finite!). Breadth-first Search is faster than DFS when the required information is closer 
to the root of the beginning of the search. However, the total speed depends on the information storage 
procedure. 

The memory requirement of Breadth-first Search is high because it saves each level record [14] and 
this is its main limitation. It is mainly used to find the shortest path between any two nodes in a graph such as 
road networks, computer networks; social networks (e.g. Facebook) [15]. 


2.3. Best-First Search (BFS) 

Best-first search is classified as a heuristic search algorithm, which uses the distance from a current 
node with respect to the target point in order to find a path in a graph. BFS is an instance of graph search 
algorithm in which a node is selected for expansion based on evaluation function f (n) [17-18]. A heuristic is 
used for making a guess of such distance. Traditionally, the node which is the lowest evaluation is selected 
for the explanation because the evaluation measures the distance to the goal. The current node’s heuristic cost 
is compared with all other nodes’ cost to determine the path in a graph, when BFS is applied. It by-passes 
few branches to the search tree leading to the non-assurance about the discovery of the shortest path. 
Best first search is the combination of breadth first search and DFS algorithms and it 1s employed through a 
priority queue in a general search framework where the data structure maintains the fringe in the ascending 
order of values. 

BFS algorithm is often referred greedy algorithm because it quickly attacks the most desirable path 
as soon as its heuristic weight becomes the most desirable. However, its searching action is lesser than 
Diykstra’s algorithm. BFS utilizes a priority queue Like Dijkstra’s to gather the list of nodes. The start node is 
assigned in the priority queue as first. With expansion, the neighboring nodes are directly connected by 
having their respective total heuristic cost and they are also stored in the priority queue. The nodes having 
minimum cost are expanded in the succeeding level. Other nodes in the queue then added. Till the reaching 
of the target point, this process is repeated. 

Best-first search algorithm by-passes few branches to the search tree leading to the non-assurance 
about the discovery of the shortest path. Certain cost 1s considered for the goal from the current state. Due to 
the heuristic function, few paths look good to be continued. Sometimes, it covers more distance than our 
consideration. On the other hand, BFS guides up to the goal by acquiring the domain information. The time 
complexity of BFS is much less than Breadth first search. The Best first search allows us to switch between 
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paths by gaining the benefits of both breadths first and depth first search. Games and web crawlers applied 
BFS and its advanced variants [21] as a path-finding algorithm. For example, in the game the enemy agent 
can be assigned by it for finding the player’s location. Some games divide up the terrain into “tiles” which 
can either be blocked or unblocked. In such cases, the search algorithm treats each tile as a node, with the 
neighboring unblocked tiles being successor nodes, and the goal node being the destination tile [22]. 


2.4. Dijkstra’s algorithmEdsger 

Diykstra’s introduced this systematic search algorithm in 1959 [23] to find an optimal path in 
between the initial and all other points in the graph as per the costs associated with traversal. The priority 
queue saves the cost of the nodes which is non-negative. Dijkstra’s algorithm visits all the nodes within the 
graph starting from an initial point and it is complete if a solution exists. It does not calculate the distance 
between each node and the target in optimal cases, if no prior knowledge of the graph exists. Dijkstra’s 
algorithm does a blind search for which lots of time are required and wastage of necessary resources occur 
while processing. 

All the nodes in a provided weighted graph are searched in this method based on their respective 
distance from the starting point in an increasing order. The nearest node from the initial point 1s determined 
by the priority queue that operates in a monotonic way. In discrete event simulation, events are prioritized by 
the times at which they happen and again are extracted monotonically. Likewise, the events where the point 
of interest is crossed by a sweep line are prioritized in computational geometry’s sweep line algorithms by 
the coordinates of the crossed point and they are done in monotonic order that occurs in the BSF branch and 
bound [21-22]. 

Prior information about target node is not required in Diyjkstra’s and hence, this makes it an 
uninformed algorithm. It is applicable in an environment with multiple nodes without any priori about the 
closest node. At each step, it chooses the edges having smallest cost and occasionally, does not need to 
investigate all the edges. Since it is more general, therefore it 1s open not only to acyclic graphs, but to others 
also. Usually it searches a huge territory in the graph and thus, applicable in geographical maps, e.g, Google 
map. In this algorithm, edges that have positive weights are stored in a priority queue and they are referred by 
the distance between the locations. In IP routing also Diykstra’s can be used so that in the beginning the Open 
shortest Path can be found, such as in telephone network. 

Palossi et al. implemented Dijkstra's algorithm for an energy-efficient shortest trajectory planning 
[26]. For multi-rotor UAVs they utilized Intel's HD Graphics accelerator that is generally applied in such 
missions where human operator’s increasing audio-visual competency is required, such as rescue mission. 
The proposed method saved about 98 % of required energy by the sequential version. Anjali Jain et al. 
implemented the modified Diykstra’s algorithm which can also increase the performance of finding out the 
shortest route with minimum iterations and saves cost as well as energy [27]. J. T. Economou et al. also used 
this algorithm to propose 4-zone strategy that was effective in a multi-scenario method to map the UAV 
mission. The achieved result revealed that the optimum path was dependent on the minimization of the gross 
propulsion energy [28]. 


2.5. A* Search Algorithm 

In 1968, Hart [29] proposed a heuristic search method A*. The forward cost function, h(n) along 
with backward cost function, g(n) in between the source and current nodes are used in this algorithm to 
calculate the total cost function f(n) as is expressed below combining both the Best-first search and Diyjkstra’s 
algorithm: 

f (n)=g(n) + h(n) 

Generally it ignores the obstacle in between the current and target node to find the heuristic value 
that is is a straight line distance [1]. A* seems to be more like Dijkstra's algorithm when the backward cost is 
prevailing resulting in the shortest path between the source and target nodes. But A* becomes Diykstra’s 
Algorithm for zero heuristic and when the searches are for longer time in extreme cases. Conversely, 
A* seems to be BFS with dominant forward cost or heuristic weighting to producing a fast non-guaranteed 
shortest path. Nevertheless, it is not possible to calculate in advance the true heuristic value [9]. Total number 
of nodes to be discovered by A* are reduced by the heuristic function where the start node is saved in the 
priority queue as the first node with which other neighboring nodes are directly connected. Then the start 
node is associated with their corresponding total cost and stored in the priority queue. In next step, the least 
cost neighboring node expands and other adjacent nodes that are not in the queue are added. Till the target 
point comes in the queue, this process repeats itself. When the heuristic value is lesser than the actual value 
A* algorithm provides optimal value by giving guaranty to generate a least cost path in between the starting 
and target points. If a solution exists, then A* 1s complete only when the time and memory are unlimited. 
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The A* search algorithm is an example of a best-first search and known as B*. Best-first algorithms 
are often used for path finding in the combinatorial search which is a best-first graph search algorithm that 
finds the least-cost path from a given initial node to any goal node [19-20]. 

A* takes much processing time and decreases the work speed. To overcome this problem Guruji et 
al. proposed a modified A* algorithm [30] which reduced the processing time at least by 65%. Thus it can be 
concluded that the modified A* algorithm is better in terms of processing time trading off a little cost of path 
length and can be applicable for fast processing applications. Sudhakara et al. developed Enhanced A* 
algorithm which provided a much shorter time of travel as compared to that of the modified A* Algorithm 
[31]. Therefore, the Enhanced A* Algorithm can accommodate a provision for generating a better control of 
the robot and pave the way for expediting an effective contrivance for exploring path planning in robotics. 
A route was found in [16] with either minimum fuel consumption or shortest traveling time by implementing 
vehicular-ad-hoc-network- (VANET-) based A* (VBA*) route planning algorithm. A* is best regarding the 
shortest distance, but the algorithm need a longer computational time. The algorithm is not appropriate to the 
situation for sequential tasks are assigned for robot [24]. The path planning with energy considerations 
insight were generated by weighted A* search to obtain the global navigation strategy [25]. 


3. RESULTS AND ANALYSIS 

DFS is good to pick up only solution among many possibilities without caring about exactly which 
one. It may be less appropriate when there is only one solution, or if the shortest one is needed. DFS is good 
because a solution can be found without computing all nodes 

Breadth-first search is suitable for limited available solutions that use a comparatively small number 
of steps. Its exceptional property finds the shortest path from the source node up to the node that it visited 
first time when all the graph’s edges are either un-weighted or having similar weight. Breadth-first search 1s 
complete if one exists. Breadth-first search is good because it does not get trapped in dead ends. 

BFS algorithm does not assure to discover the shortest path because it bypasses some branches in 
the search tree. It is a greedy search which is not complete and optimal. 

Diykstra’s algorithm is systematic search algorithm and gives shortest path between two nodes. 
In optimal cases, where there is no prior knowledge of the graph, it cannot estimate the distance between 
each node and the target. Usually, a large area is covered in the graph by Diyjkstra’s due to its selection of 
edges with minimum cost at every step and thus, it is significant for the situation having multiple target nodes 
without any prior knowledge of the closest one. 

A* is not very optimal because it needs to be executed a number of times for each target node to get 
them all. A* expands on a node only if it seems promising. It only aims to reach the target from the current 
node at the earliest and does not attempt to reach any other node. A* 1s complete because it always finds a 
path if one exists. By modifying the used heuristics and node’s evaluation tactics of A*, other path-finding 
algorithm can be developed. Dijkstra and the BFS can be simulated in this way. Table 1 compares the 
discussed graph search methods in terms of path optimality, computation time, real time capability, 
memory usage, safety and completeness. 


Table. 1 Comparison of Graph Search Methods 


Graph Search Method 
Method Optimal Path Computational Time Real-time © Memory Safety Completeness 
Depth-First Search x x x V x V 
Breadth-First Search x x x V x V 
Dikstra’s V x x “ V V 
Best First x V V V x V 
A* x V V V V V 


4. CONCLUSION 

Several path planning algorithms were implemented by earlier researchers and now it is 
multidimensional. The main objectives are to make a path planning efficient depends on (i) minimal 
computation time, (11) optimal collision-free path, (111) energy efficiency, and (iv) completeness. This work 
concentrated on graph search algorithms considering the objectives of UAV’s mission where energy 
efficiency and their nature of motion, advantages, and drawbacks were taken care. According to the obtained 
results such as safety, completeness and computation time, an optimization can be done to make it an energy- 
efficient path planning algorithm. 
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